<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>Document</title>
    <script src="./js/vue.js"></script>
    <script src="./js/day.min.js"></script>
  </head>
  <!-- 
			过滤器：
				定义：对要显示的数据进行特定格式化后再显示（适用于一些简单逻辑的处理）。复杂的需要用计算属性
				语法：
						1.注册过滤器：Vue.filter(name,callback) 或 new Vue{filters:{}}
						2.使用过滤器：{{ xxx | 过滤器名}}  或  v-bind:属性 = "xxx | 过滤器名"
				备注：
						1.过滤器也可以接收额外参数、多个过滤器也可以串联
						2.并没有改变原本的数据, 是产生新的对应的数据
		-->
  <body>
    <div id="root">
      当前时间是:{{time | timeFormat}}
      <br />
      只取时间前四位{{time | timeFormat | msgslice}}
      <br />
      msg:{{msg | msgslice}}
    </div>

    <script>
      //创建全局过滤器
      // Vue.filter("msgslice",function(value){
      //   return value.slice(0, 4);
      // })

      //创建Vue实例,得到 ViewModel
      const vm = new Vue({
        el: '#root',
        data: {
          time: 1621561377603,
          msg: 'hello,world!!',
        },
        methods: {},
        computed: {},
        // 创建局部过滤器
        filters: {
          timeFormat(value) {
            return dayjs(value).format('YYYY-MM-DD HH:mm:ss');
          },
          msgslice(value) {
            return value.slice(0, 4);
          },
        },
      });
    </script>
  </body>
</html>
